

# WinCE MLC Solution Pre-Programming Guide



ELECTRONICS

WinCE 5.0/6.0 MLC NAND Solution (PocketMory) Pre-Programming Guide

Copyright © 2006-2010 Samsung Electronics Co, Ltd. All Rights Reserved.

Though every care has been taken to ensure the accuracy of this document, Samsung

Electronics Co, Ltd. cannot accept responsibility for any errors or omissions or for any loss

occasioned to any person, whether legal or natural, from acting, or refraining from action, as a

result of the information contained herein. Information in this document is subject to change at

any time without obligation to notify any person of such changes.

Samsung Electronics Co, Ltd. may have patents or patent pending applications, trademarks

copyrights or other intellectual property rights covering subject matter in this document. The

furnishing of this document does not give the recipient or reader any license to these patents,

trademarks copyrights or other intellectual property rights.

No part of this document may be communicated, distributed, reproduced or transmitted in any

form or by any means, electronic or mechanical or otherwise, for any purpose, without the prior

written permission of Samsung Electronics Co, Ltd.

The document is subject to revision without further notice.

All brand names and product names mentioned in this document are trademarks or registered

trademarks of their respective owners.

Contact Email: mobilesol.cs@samsung.com



# **Revision History**

| Date                    | Version | Author     | Amendment                                     |  |  |
|-------------------------|---------|------------|-----------------------------------------------|--|--|
| 2007.06.18              | 0.1     | HM.SEO     | Master Copy                                   |  |  |
| 2007.06.22              | 0.2     | HM.SEO     | Master Copy                                   |  |  |
| 2007.06.26              | 0.3     | HM.SEO     | Master Copy                                   |  |  |
| 2007.06.29              | 0.4     | HM.SEO     | Master Copy                                   |  |  |
| 2008.05.19              | 0.41    | TS TEAM    | Master Copy                                   |  |  |
| 2008.06.23              | 1.0     | D/D TEAM   |                                               |  |  |
| 2010 06 19              | 1.1     | CCE TEAM   | PMSMDMaker v3.0                               |  |  |
| 2010-06-18 1.1 CSE TEAM |         | CSE TEAIVI | - S5P6440 and S5P6443 are supported.          |  |  |
| 2010-06-23              | 1.2     | CSE TEAM   | PMSMDMaker v3.1                               |  |  |
| 2010-00-23              | 1.2     | COE TEAIVI | - 8KB page sized MLC NAND flash is supported. |  |  |



# Contents

| 1 | Overview                                                           | 6  |
|---|--------------------------------------------------------------------|----|
| 2 | Make SMD Binary Image Using PMSMDMaker                             | 7  |
|   | 2.1 PMSMDMaker Application                                         | 7  |
|   | 2.2 MLC NAND Type                                                  | 8  |
|   | 2.3 Block 0 Image                                                  | 8  |
|   | 2.3.1 Nbl1                                                         | 8  |
|   | 2.3.2 Nbl2                                                         | 8  |
|   | 2.3.2.1 2KB and 4KB page sized MLC NAND flash                      | 8  |
|   | 2.3.2.2 8KB page sized MLC NAND flash                              | 9  |
|   | 2.4 127 Page Image                                                 | 10 |
|   | 2.5 TOC Image                                                      | 10 |
|   | 2.6 Eboot Image                                                    | 10 |
|   | 2.7 Ext Image                                                      | 10 |
|   | 2.8 OS and Filesystem Image                                        | 11 |
|   | 2.9 Enter the block address for each regions                       | 11 |
|   | 2.10 Make SMD file button                                          | 11 |
|   | 2.11 Save Log button                                               | 11 |
|   | 2.12 Load Log button                                               | 11 |
| 3 | How to extracts OS image and File System Image from target device? | 12 |
|   | 3.1 DumpImage.exe Application                                      | 12 |
| 4 | Guides for Mass-product                                            | 20 |
|   | 4.1 PocketMory Block Mapping Example                               | 20 |
|   | 4.2 The SMD binary format                                          | 22 |
|   | 4.3 The VFLCxt Section format                                      | 27 |
|   | 4.4 Block 0 Image                                                  | 35 |
|   | 4.4.1 Step loader image                                            | 36 |
|   | 4.4.2 Second Boot loader image                                     | 36 |
|   | 4.4.3 VFLCxt Bad block info block (126 Page )                      | 37 |
|   | 4.4.4 PocketMory Version information (127 Page)                    | 38 |
|   | 4.5 TOC Image                                                      | 39 |
|   | 4.6 Eboot Image                                                    | 39 |
|   | 4.7 Ext Image                                                      | 39 |
|   | 4.8 OS Image                                                       | 40 |

4



# MLC NAND Flash Pre-Programming Guide/ AP Development Team / PG-10-06-23

| 4.9  | File system Image          | 41 |
|------|----------------------------|----|
| 4.10 | Total block mapping sample | 42 |



# 1 Overview

This documentation explains below listed articles.

- How to make SMD binary Image for NAND pre-programming.
- The structure of SMD binary.
- How to programming each parts (Block 0, TOC, Eboot, OS, Filesystem, VFL Info Area)
- How to control the bad block.



# 2 Make SMD Binary Image Using PMSMDMaker

#### 2.1 PMSMDMaker Application

The PMSMDMaker application can make SMD binary for MLC NAND flash Mass-production.

You have to fill all information before make SMD binary.

And press the "Make SMD File" button. Then you can make SMD binary file.





# 2.2 MLC NAND Type

Choose the NAND flash type what you using.

The PMSMDMaker v3.1 can support listed 14 MLC NAND flash types.

- K9G4G08
- K9G8G08
- K9L8G08
- K9LAG08
- K9GAG08U0M(4BIT ECC)
- K9GAG08U0D(8BIT ECC)
- K9GAG08U0E(16BIT ECC)
- K9GBG08U0M(16BIT ECC)
- K9HAG08
- K9HBG08
- K9LBG08U0M(4BIT ECC)
- K9LBG08U0D(8BIT ECC)
- K9HCG08U0M(4BIT ECC)
- K9HCG08U0D(8BIT ECC)

#### 2.3 Block 0 Image

Block 0 image is combined nbl1 and nbl2 image.

# 2.3.1 Nbl1

Nbl1 image will be written on page number from 0 to 3(from 0 to 2 for 8KB page sized MLC NAND flash) on block 0. This image is copied to stepping stone automatically at boot up time by iROM booting.

### 2.3.2 Nbl2

2.3.2.1 2KB and 4KB page sized MLC NAND flash

The Nbl2 image will be written on from page number 10.

The Nbl1 have to load the Nbl2 from page number 10.

The block0 page mapping information is as below.

| Page Number |                                     |
|-------------|-------------------------------------|
| 0~3         | Nbl1                                |
| 10~125      | Nbl2                                |
| 126         | Bad information for VFLInfoSection. |
| 127         | PocketMory Version Information      |



# 2.3.2.2 8KB page sized MLC NAND flash

The Nbl2 image will be written on from page number 9.

The Nbl1 have to load the Nbl2 from page number 9.

The block0 page mapping information is as below.

| Page Number |                                     |
|-------------|-------------------------------------|
| 0~2         | Nbl1                                |
| 9~125       | Nbl2                                |
| 126         | Bad information for VFLInfoSection. |
| 127         | PocketMory Version Information      |



#### 2.4 127 Page Image

The Block 0 page 127 has PocketMory Version information.

This image have only 4 byte version information like as below

```
Page Number [99999999 to exit] = 127
Main Data
57 30 32 32 ff ff
11 11 11 11 11 11 11 11 11 11 11 11
ff ff
ff ff ff ff ff ff ff ff ff ff ff ff
ff ff ff ff ff ff ff ff ff ff ff
ff ff ff ff ff ff ff ff ff ff
 ff ff ff ff ff ff ff ff ff ff ff ff
ff ff ff ff ff ff ff ff ff ff ff ff ff
f9 25 35 2b c0 70 70 00 d7 ec 33 c6 69 53 80 00
d7 ec 33 c6 69 53 80 00 d7 ec 33 c6 69 53 80 00
41 5a 90 f0 36 a4 88 00 41 5a 90 f0 36 a4 88 00
```

#### 2.5 TOC Image

You can make it easy using FIL read function in our Eboot code.

Or, you can make it using the DumpImage tool of the SMDK BSP.

#### 2.6 Eboot Image

Choose Eboot.nb0 image.

# 2.7 Ext Image

If you want to write additional image like booting logo, you can use this one.



# 2.8 OS and Filesystem Image

Choose OSIMG.IMG file and FTLIMG.IMG file.

It will explain from next page for about how to make those files using the Dumplmage tool of the SMDK BSP.

# 2.9 Enter the block address for each regions

Set the TOC Block, Eboot Block, Special Area Start Block, VFLInfo Block, FTL Start Block.

#### 2.10 Make SMD file button

To make SMD binary image, use this function

# 2.11 Save Log button

This function is for save log.

# 2.12 Load Log button

This function is for load previous saved configuration.



# 3 How to extracts OS image and File System Image from target device?

# 3.1 DumpImage.exe Application

You need some application to extract OS and File system image.

Sample code is in "\_TARGETPLATROOT\Src\Apps\DumpImage" for WinCE5.0 PM BSP.

In case of WinCE6.0 PM, the sample code is located at the \_TARGETPLATROOT \ETC\PMSMDMaker\DumpImage.

You have to change some definition on Dumplmage application source code.

At first you have to change the block address for OS area like as below sample.

| #define PAGESIZE2K             | 1    |
|--------------------------------|------|
| #define SPECIAL_AREA_START_L   | 10   |
| #define SPECIAL_AREA_SIZE_L    | 50   |
| #define FTL_AREA_START_L       | 166  |
| #define FTL_AREA_SIZE_L        | 1882 |
| #define PAGES_PER_SUBLK_L      | 256  |
|                                |      |
| #define SECTORS_PER_PAGE_L     | 4    |
| #define BYTES_PER_SECTOR_L     | 512  |
| #define BYTES_PER_SPARE_L      | 16   |
| #define BYTES_PER_SPARE_PAGE_L | 128  |
|                                |      |
| #define USE2PLANE_L            |      |

This sample is for K9LAG08 MLC NAND Flash.

You can get these values with booting message.

If you use our default BSP, then you can get below message through UART debug message.



# 

- [FIL] FIL Global Information
- [FIL] BANKS\_TOTAL = 2
- [FIL] BLOCKS\_PER\_BANK = 2048
- [FIL] TWO\_PLANE\_PROGRAM = 1
- [FIL] SUPPORT INTERLEAVING = 1
- [FIL] SUBLKS\_TOTAL = 2048
- [FIL] PAGES\_PER\_SUBLK = 256
- [FIL] PAGES\_PER\_BANK = 262144
- [FIL] SECTORS\_PER\_PAGE = 4
- [FIL] SECTORS\_PER\_SUPAGE = 8
- [FIL] SECTORS\_PER\_SUBLK = 2048
- [FIL] USER SECTORS TOTAL = 3799040
- [FIL] ADDRESS\_CYCLE = 5
- [INFO] WMR\_AREA\_SIZE = 10
- [INFO] SPECIAL AREA START = 10
- [INFO] SPECIAL AREA SIZE = 50
- [INFO] VFL\_AREA\_START = 60
- [INFO] VFL AREA SIZE = 106
- [INFO] VFL\_INFO\_SECTION\_START = 60
- [INFO] VFL\_INFO\_SECTION\_SIZE = 4
- [INFO] RESERVED\_SECTION\_START = 64
- [INFO] RESERVED\_SECTION\_SIZE = 102
- [INFO] FTL\_INFO\_SECTION\_START = 166
- [INFO] FTL\_INFO\_SECTION\_SIZE = 10
- [INFO] LOG\_SECTION\_SIZE = 7
- [INFO] FREE\_SECTION\_START = 176
- [INFO] FREE\_SECTION\_SIZE = 17
- [INFO]  $FREE\_LIST\_SIZE = 3$
- [INFO] DATA\_SECTION\_START = 193
- [INFO] DATA SECTION SIZE = 1855
- [INFO] FTL\_AREA\_START = 166
- [INFO] FTL AREA SIZE = 1882



BYTES\_PER\_SPARE\_PAGE\_L value is 128 or 256.

If you use 8bit ECC device (K9LBG08U0D) please set this value to 256. (128 for 4bit ECC device)

This DumpImage.c file is divided by 3 parts.

At first step, it will create the output file.

The below sample code will make OSIMG.IMG file to "Storage Card" folder.

The "Storage Card" folder can be SD Memory card.

```
// Extract OS Image routine...

RETAILMSG(1,(TEXT("Dump OS Image\r\n")));

pFileOutPtr = fopen("Storage Card/OSIMG.IMG", "wb");

if (!pFileOutPtr)
{
         RETAILMSG(1,(TEXT("Storage Card/OSIMG.IMG file is not opened.!!!\r\n")));
         goto Fail;
}

fseek(pFileOutPtr, 0, SEEK_SET);
```

The second step is scanning all OS area to check last valuable data. It checks all FF area.

```
dwOSStartPage = SPECIAL_AREA_START_L * PAGES_PER_SUBLK_L;
dwOSEndPage = ( SPECIAL_AREA_START_L + SPECIAL_AREA_SIZE_L ) *
PAGES_PER_SUBLK_L - 1;

RETAILMSG(1,(TEXT("OS Area is from %d to %d\r\n"), dwOSStartPage, dwOSEndPage));
RETAILMSG(1,(TEXT("Scanning...\r\n")));
// Scan All FF area
for ( nVpn = dwOSEndPage; nVpn > dwOSStartPage; nVpn-- )
{
    memset(pData, 0xFF, sizeof(pData));
    memset(pSpare, 0xFF, sizeof(pSpare));
    ReadPage( nVpn, pData, pSpare );
```



And the last step is for dump image using ReadPage function.

```
for( nVpn=dwOSStartPage; nVpn<dwOSEndPage; nVpn++ )</pre>
        memset(pData, 0xFF, sizeof(pData));
        memset(pSpare, 0xFF, sizeof(pSpare));
        ReadPage( nVpn, pData, pSpare );
#ifdef USE2PLANE L
       // Write First plane
       fwrite(pData,
                     sizeof(char),
                                  (SECTORS_PER_PAGE_L*BYTES_PER_SECTOR_L),
pFileOutPtr);
       fwrite(pSpare,
                      sizeof(char),
                                   (SECTORS_PER_PAGE_L*BYTES_PER_SPARE_L),
pFileOutPtr);
       // Write Second plane
       fwrite(pData+(SECTORS_PER_PAGE_L*BYTES_PER_SECTOR_L),
                                                                        sizeof(char),
(SECTORS_PER_PAGE_L*BYTES_PER_SECTOR_L), pFileOutPtr);
        fwrite(pSpare+(SECTORS_PER_PAGE_L*BYTES_PER_SPARE_L),
                                                                        sizeof(char),
(SECTORS_PER_PAGE_L*BYTES_PER_SPARE_L), pFileOutPtr);
#else
```



```
// Write First plane
fwrite(pData, sizeof(char), (SECTORS_PER_PAGE_L*BYTES_PER_SECTOR_L),
pFileOutPtr);
fwrite(pSpare, sizeof(char), (SECTORS_PER_PAGE_L*BYTES_PER_SPARE_L),
pFileOutPtr);
#endif
}
if (pFileOutPtr) fclose(pFileOutPtr);

RETAILMSG(1,(TEXT("Dump OS Image Finished\r\n")));
```

The ReadPage use Kernel IO control to read each page.

It can not read main data area and spare area at same time.

That's why the Kernel IO control has to be called twice.

```
void ReadPage(DWORD nVpn, unsigned char * pData, unsigned char * pSpare)
        Buffer
                         pBuf;
        VFLPacket
                         stPacket;
        UINT32
                         nResult;
#ifdef PAGESIZE4K
        #ifdef USE2PLANE L
                 pBuf.nBitmap = 0xFFFF;
        #else
                 pBuf.nBitmap = 0xFF;
        #endif
#else
        #ifdef USE2PLANE_L
                 pBuf.nBitmap = 0xFF;
        #else
                 pBuf.nBitmap = 0xF;
        #endif
#endif
```



```
pBuf.eStatus = BUF_AUX;
        pBuf.nBank = 0;
        // Read Main Data Area
        pBuf.pData = pData;
        pBuf.pSpare = NULL;
        do {
            /* VFL Read */
            stPacket.nCtrlCode = PM_HAL_VFL_READ;
            stPacket.nVbn
                                 = 0;
                                                 // Not used
            stPacket.nVpn
                                 = nVpn;
            stPacket.pBuf
                                = &pBuf;
            stPacket.nSrcVpn
                                 = 0;
            stPacket.nDesVpn
                                 = 0;
            stPacket.bCleanCheck= FALSE32;
            KernelloControl(IOCTL_POCKETSTOREII_CMD, /* IO Control Code */
                             &stPacket,
                                                /* Input buffer (Additional Control Code) */
                             sizeof(VFLPacket), /* Size of Input buffer */
                             NULL.
                                                /* Output buffer */
                                                /* Size of Output buffer */
                             0,
                                                 /* Error Return */
                             &nResult);
            if (nResult != VFL_SUCCESS)
                RETAILMSG(1, ((TEXT("[VFLP:ERR] VFL_Read()
                                                                          failure.
                                                                                    ERR
Code=%x\r\n"), nResult)));
                break;
            }
        } while(0);
        // Read Spare Area
        pBuf.pData = NULL;
        pBuf.pSpare = pSpare;
```



```
do {
            /* VFL_Read */
            stPacket.nCtrlCode = PM_HAL_VFL_READ;
            stPacket.nVbn
                                                 // Not used
                                 = 0;
            stPacket.nVpn
                                 = nVpn;
            stPacket.pBuf
                                = &pBuf;
            stPacket.nSrcVpn
                                 = 0;
            stPacket.nDesVpn
                                 = 0:
            stPacket.bCleanCheck= FALSE32;
            KernelloControl(IOCTL_POCKETSTOREII_CMD, /* IO Control Code */
                             &stPacket,
                                                /* Input buffer (Additional Control Code) */
                             sizeof(VFLPacket), /* Size of Input buffer */
                             NULL,
                                                /* Output buffer */
                             0.
                                                /* Size of Output buffer */
                                                /* Error Return */
                             &nResult);
            if (nResult != VFL_SUCCESS)
                RETAILMSG(1, ((TEXT("[VFLP:ERR]
                                                          VFL Read()
                                                                          failure.
                                                                                    ERR
Code=%x\r\n"), nResult)));
                break;
            }
        } while(0);
```

Build "DumpImage.c" file and copy the "DumpImage.exe" file to target device and execute it. Then you can get the OS image and FTL image with below UART output message.

```
Dump OS Image
OS Area is from 2560 to 11007
Scanning...
Read Sector from 2560 to 7873
Dump OS Image Finished
```

# MLC NAND Flash Pre-Programming Guide/ AP Development Team / PG-10-06-23

| Dump FTL Image |
|----------------|
|----------------|

FTL Area is from 38144 to 524287

Scanning...

Read Sector from 38144 to 53470

Dump FTL Image Finished



# 4 Guides for Mass-product

#### 4.1 PocketMory Block Mapping Example

The PocketMory block structure is seems as below table.

| Bloc Number ( Logical Block ) | Image Name                        |  |  |  |  |
|-------------------------------|-----------------------------------|--|--|--|--|
| 0                             | Block 0 Image                     |  |  |  |  |
| 1~2                           | TOC block                         |  |  |  |  |
| 3~9                           | Eboot Block                       |  |  |  |  |
| 10~59                         | OS Area ( Special Area )          |  |  |  |  |
| 60~63                         | VFL Info Area                     |  |  |  |  |
| 64~165                        | VFL Reserved Area ( for Bad Block |  |  |  |  |
|                               | remapping)                        |  |  |  |  |
| 166~2047                      | FTL Area                          |  |  |  |  |

This block mapping example is based on our SMDK2450 BSP with K9LAG08 MLC NAND flash. The block number is logical block. If the MLC NAND flash driver can support 2-plane programming, then the logical 1 block has physical 2 blocks. If the MLC NAND flash can support inter-leaving operation, the logical 1 block has physical 4 blocks.

For understanding about 2-plane programming and Inter-leaving, below description is quoted from MLC NAND flash specification.

Quotation from the K9LAG08U0M\_0.8\_MLC specification:

K9LAG08U0M is arranged in four 4Gb memory planes. Each plane contains 2,048 blocks and 2112 byte page registers. This allows it to perform simultaneous page program and block erase by selecting one page or block from each plane. The block address map is configured so that two-plane program/erase operations can be executed by dividing the memory array into plane 0~1 or plane 2~3 separately.

For example, two-plane program/erase operation into plane 0 and plane 2 is prohibited. That is to say, two-plane program/erase operation into plane 0 and plane 1 or into plane 2 and plane 3 is allowed





For example, if the OS start block is from logical block 1, the OS image write procedure is as below.

Block 2 Page 0 -> Block 3 Page 0 -> Block 4098 Page 0 -> Block 4099 Page 0 ->

Block 2 Page 1 -> Block 3 Page 1 -> Block 4098 Page 1 -> Block 4099 Page 1 -> ...

If the file system start block is logical block N, then the physical block is 2\*N, 2\*N + 1, (Total Block Number / 2) + 2\*N, (Total Block Number / 2) + 2\*N + 1.



# 4.2 The SMD binary format

The SMD binary format is follow the structure of SMDHEADER.

The structure of SMDHEADER is as below.

| #define SMDHEADER_REALDATASIZE 0xA4      |                 |
|------------------------------------------|-----------------|
| typedef struct _SMDHEADER {              |                 |
| DWORD dwSig;                             | // 00           |
| BOOL32bUse2Plane;                        | // 04           |
|                                          |                 |
| BOOL32bUseInterLeaving;                  | // 08           |
| BOOL32bUseCEInterLeaving;                | // 0C           |
| DWORD dwTotalBlockNumber;                | // 10           |
| DWORDdwMainPageSize;                     | // 14           |
| DWORD dwSparePageSize;                   | // 18           |
| DIA/ODD divices signatures Chartelle str | // 40           |
| DWORD dwSpecialAreaStartBlock;           | // 1C           |
| DWORD dwVFLInfoSectionStartBlock;        | // 20<br>// 2.1 |
| DWORD dwReservedSectionStartBlock;       | // 24           |
| DWORD dwReservedSectionBlockNumber;      |                 |
| DWORD dwFTLInfoSectonStartBlock;         | // 2C           |
| DWORDdw2ndBLStartPageNumber;             | // 30           |
| DWORD dw2ndLLastPageNumber;              | // 34           |
| DWODD div.TOCDs as North or              | // 20           |
| DWORDdwTOCPageNumber;                    | // 38           |
| DWORD dwEBootStartPageNumber;            | // 3C           |
| DWORD dwEBootLastPageNumber;             | // 40           |
| DWORD dwExtStartPageNumber;              | // 44           |
|                                          |                 |
| DWORD dwExtLastPageNumber;               | // 48           |
| DWORD dwOSStartPageNumber;               | // 4C           |
| DWORDdwOSLastPageNumber;                 | // 50           |



| DWORD dwVFLInfoSectionPageNumber; | // 54                           |
|-----------------------------------|---------------------------------|
| DWORDdwFTLStartPageNumber;        | // 58                           |
| DWORDdwFTLLastPageNumber;         | // 5C                           |
| DWORDdwStepLDRAddress;            | // 60                           |
| DWORDdwStepLDRSize;               | // 64                           |
| DWORDdw2ndBLAddress;              | // 68                           |
| DWORD dw2ndBLSize;                | // 6C                           |
| DWORD dw127Address;               | // 70                           |
| DWORD dw127Size;                  | // 74                           |
| DWORDdwTOCAddress;                | // 78                           |
| DWORD dwTOCSize;                  | // 7C                           |
| DWORD dwEbootAddress;             | // 80                           |
| DWORD dwEbootSize;                | // 84                           |
| DWORD dwExtAddress;               | // 88                           |
| DWORD dwExtSize;                  | // 8C                           |
| DWORDdwOSAddress;                 | // 90                           |
| DWORD dwOSSize;                   | // 94                           |
| DWORDdwFTLAddress;                | // 98                           |
| DWORDdwFTLSize;                   | // 9C                           |
| DWORD dwPSMDCheckSum;             | // A0                           |
| DWORDpad[((2048+64)/4)-SMDHEADER_ | _REALDATASIZE/4]; // Make Total |
| Size to 2048 + 64                 |                                 |
| } SMDHEADER, *PSMDHEADER;         |                                 |

Each member values are defined as blow.

- dwSig: The signature of SMD binary. (ex: PM20)
- bUse2Plane : Option for using 2 plane or not. Every MLC NAND flash support 2-plane programming.
- bUseInterLeaving: Option for using Inter-leaving or not. The MLC DDP and QDP can support Inter-leaving programming.
- bUseCEInterLeaving: If this value is TRUE, this nand device has 2 CE. This MLC
   NAND flash will be QDP. (Ex:K9HAG08, K9HBG08)
- dwTotalBlockNumber : The total block number for MLC NAND flash. This block number is physical block number.



- dwMainPageSize : This value indicates the main area size for each page. This value is 2048 or 4096.
- dwSparePageSize: This value indicates the spare area size for each page. This value is 64, 128 or 256.
- dwSpecialAreaStartBlock: The Special Area is used for OS region. This block number is logical block number. If the NAND flash support 2-plane programming, for example, the logical block 10 is physical block 20 and 21. If the NAND flash support 2-plane programming and inter-leaving, the logical block 10 is physical block 20, 21, 4096 + 20 and 4096 + 21. (Assume to dwTotalBlockNumber is 8192)
- dwVFLInfoSectionStartBlock: This value indicates the VFLInfo section block. VFLInfo section has bad block information and mapping table. The VFLInfo structure will described on next chapter. This block number is logical block number.
- dwReservedSectionStartBlock: This block number is reserved area start block for bad block re-mapping. This block number is logical block number.
- dwReservedSectionBlockNumber: The reserved block numbers for bad block remapping. This number is depends on NAND flash specification.
- dwFTLInfoSectonStartBlock: This block number indicates the file system area start block. This number is logical block number.
- dw2ndBLStartPageNumber: This number is indicates the start page number of Nbl2 (Second Bootloader). This page number is physical page number. Because the 2<sup>nd</sup> boot loader is programmed on physical block 0 of plane 0 only. The physical block 0 is only guaranteed by NAND flash manufacture. In normal case this number is 10.
- dw2ndBLLastPageNumber: This page number is last page number for 2<sup>nd</sup> boot loader.
   This page number is physical page number.
- dwTOCPageNumber: This number is page number for TOC information. This page number is logical page number. The TOC information is only programmed on plane 0.
- dwEBootStartPageNumber: This number is page number for Eboot area start page.
   This page number is logical page number. The Eboot information is only programmed on plane 0.
- dwEbootLastPageNumber: This number is size of Eboot regions. This page number is logical page number.
- dwExtStartPageNumber: This number is page number for Ext area start page. This
  page number is logical page number. The Ext information is only programmed on plane
  0.
- dwExtLastPageNumber: This number is size of Ext regions. This page number is logical page number.



- dwOSStartPageNumber: This page number is start of Special area. This page number is logical number. In case of 2-plane programming, if this page number is N, the physical page number is N\*2 and N\*2 + 128. In case of inter-leaving and 2-plane programming, if this page number is N, the physical page number is N\*2, N\*2 + 128, (4096\*128) + N\*2 and (4096\*128) + N\*2 + 128.
- dwOSLastPageNumber: This page number is last page number of OS image regions.
   This page number is logical page number.
- dwVFLInfoSectionPageNumber: This page number is start of VFLInfo section. This
  page number is logical number.
- dwFTLStartPageNumber: This page number is start of file system area. This page number is logical number.
- dwFTLLastPageNumber: This page number is last page of file system area. This page number is logical number.
- dwStepLDRAddress: This number indicates the start address of step loader image in SMD binary image.
- dwStepLDRSize: This number is size of step loader.
- dw2ndBLAddress: This number indicates the start address of 2<sup>nd</sup> boot loader in SMD binary image.
- dw2ndBLSize: This number is size of 2<sup>nd</sup> boot loader.
- dw127Address: This number indicates the start address of 127 page image in SMD binary image.
- dw127Size: This number is size of 127 page image.
- dwTOCAddress: This number indicates the start address of TOC image in SMD binary image.
- dwTOCSize: This number is size of TOC image.
- dwEbootAddress: This number indicates the start address of Eboot image in SMD binary image.
- dwEbootSize: This number is size of Eboot image.
- dwExtAddress: This number indicates the start address of Ext image in SMD binary image.
- dwExtSize: This number is size of Ext image.
- dwOSAddress: This number indicates the start address of OS image in SMD binary image.
- dwOSSize: This number is size of OS image.
- dwFTLAddress: This number indicates the start address of file system image in SMD binary image.



- dwFTLSize: This number is size of file system image.



#### 4.3 The VFLCxt Section format

The VFLCxt binary format is follow the structure of VFLCxtLocalUse.

The structure of VFLCxtLocalUse is as below.

```
typedef struct {
        UINT32
                        nGlobalCxtAge;
                                                /* age for FTL meta information search */
                        aFTLCxtVbn[64 + 1];
        UINT16
                                              // WMR NUM MAPS MAX = 64
        UINT16
                        nPadding;
                                         /* context age 0xFFFFFFF --> 0x0
        UINT32 nCxtAge;
        UINT32 nCxtLocation;
                                         /* page offset, context is located */
                                                                         */
        /* this data is used for summary
        UINT16 nNumOfInitBadBlk;
                                         /* the number of initial bad blocks */
        UINT16 nNumOfWriteFail;
                                         /* the number of write fail
        UINT16 nNumOfEraseFail:
                                         /* the number of erase fail
                                                                          */
        /* bad blocks management table & good block pointer */
        UINT16 nBadMapTableMaxIdx;
        UINT16 aBadMapTable[400 * 2]; // 400 : WMR_MAX_RESERVED_SIZE
        UINT8 aBadMark[16384 / 8 / 8]; // 16384
                                                         WMR MAX VB,
                                                                           last
BAD_MARK_COMPRESS_SIZE
        /* bad blocks management table within VFL info area */
                                        // 4 : VFL_INFO_SECTION_SIZE
        UINT8 aBadInfoBlk[4];
} VFLCxtLocalUse;
```

If the MLC NAND flash can support inter-leaving programming, it needs two VFLCxt information. The VFLCxt1 has block information from physical block number 0 to 4095. And the VFLCxt2 has block information from block number 4096 to 8191. (In case of : K9LAG08)

- nGlobalCxtAge: This value is used internally. Set this value to 0 for VFLCxt1, and set to 1 for VFLCxt2.
- aFTLCxtVbn[64 + 1]: This array is filled with dwFTLInfoSectionStartBlock number. This array can be filled with below expression. The number 10 is almost fixed value. Current PocketMory Solution's FTL\_INFO\_SECTION\_SIZE is fixed to 10.

```
for (dwBlockNumber = 0; dwBlockNumber < 10; dwBlockNumber++) // 10 :
```



- nPadding: This value is just for make 4 byte align. This value is set by 0.
- nCxtAge : This value should be 0xFFFFFFF.
- nCxtLocation : This value's initial value is 3. This value indicates the VFLCxt information location. If the VFLCxt is located on first of VFL Info AREA start block, then this value is 3. Because, in the PocketMory source code, it reference the (nCxtLocation+1)%4 th indexed block. If the nCxtLocation value is 1, then the VFLCxt information is located on 3<sup>rd</sup> block from VFL Info AREA start block. And it means the 1<sup>st</sup> and 2<sup>nd</sup> block of VFL Info Area are bad blocks.
- nNumOfInitBadBlk: This value's initial value is 0. This value is number of Initial bad block. If the total initial bad block number is 5, then this value is 5.
- nNumOfWriteFail : This value should be 0.
- nNumOfEraseFail: This value should be 0.
- nBadMapTableMaxIdx : This value is calculated with below expression.

```
stVFLCxtL[dwBankCnt].nBadMapTableMaxIdx
= stVFLCxtL[dwBankCnt].nNumOfInitBadBlk/2
+ (stVFLCxtL[dwBankCnt].nNumOfInitBadBlk%2);
```

aBadMapTable[400 \* 2]: This array is bad block mapping table. If initial bad block is found, set the bad block number to this array. For example, if the block number 30 and 44 are bad block and it is first two initial bad block, then the aBadMapTable[0] value is 30 and aBadMapTable[1] value is 44. If the initial bad block is in reserved area, this array indicated value is 0xFFFF. For example, if the reserved area start block number is 100 and if the block number 105 is bad block, then the aBadMapTable[5] value is 0xFFFF. The number 5 is calculated by "105 – 100". At this time, the bad block number is physical block number. For second die, incase of inter-leaving programming, the block number is counted from half of block. For example, if the total block number is 8192 and the 4096+55 block is bad block, and it is first bad block of 2<sup>nd</sup> die, then the



stVFLCxtL2.nBadMapTable[0] value is 55 not 4151.

- aBadMark[16384 / 8 / 8]: This array's each bit indicates the bad block information. This array is calculated with below expression. This array is initialized with 0xFF and the bit will be changed from 1 to 0.

```
stVFLCxtL1.aBadMark[dwBlockNumber/8/8]
&= ~((UINT8)(1<<(7-((dwBlockNumber/8)%8))));;
```

For example, let see the below aBadMark area information. This sample MLC NAND flash has bad block on block number 2933.

Therefore the aBadMark area information looks as below.

```
ff ff ff ff ff fd ff ff ff ff ff ff ff ff
ff ff ff ff ff ff ff ff ff ff ff ff ff
```

- aBadInfoBlk[4]: The bad block info block is 4 blocks. This array is indicates the VFLInfo section is bad block or not. If the VFLInfo section is not Bad block then the value is 0. If it is bad block then the value is 0x01. Finally, this value is written to 126page of block 0.



When write the VFLCxt page, it have to make spare area information. The page lay out is structured as below.

# Page Layout for 2Kbytes/Page NAND Flash Device:

| 0~511    | 512~1023 | 1024~1535 | 1536~2047 | 2048~2111  |
|----------|----------|-----------|-----------|------------|
| Sector 0 | Sector 1 | Sector 2  | Sector 3  | Spare Area |
| 512B     | 512B     | 512B      | 512B      | 64B        |

Table 4-1. MLC Page Layout 2K page (2048+64 byte)

### Spare Area Layout for 2Kbyte/Page NAND Flash Device:

| 0(1)        | 1(1)          | 2~3(2)   | 4~15(12)         | 16~23(8)       | 24~39(8)       | 32~39(8)       | 40~47(8)       | 48~55(8)     | 56~63(8)             |
|-------------|---------------|----------|------------------|----------------|----------------|----------------|----------------|--------------|----------------------|
| Bad<br>Mark | Clean<br>Mark | Reserved | Spare<br>Context | Sector0<br>ECC | Sector1<br>ECC | Sector2<br>ECC | Sector3<br>ECC | Spare<br>ECC | Spare<br>ECC<br>copy |

Table 4-2. MLC Spare Layout 2K page (64 byte)

# Page Layout for 4Kbytes/Page NAND Flash Device (4bit ECC):

|                  | <u> </u>         |                  | 9                |                  | ,                |                  |                  |                       |
|------------------|------------------|------------------|------------------|------------------|------------------|------------------|------------------|-----------------------|
| 0~511            | 512~1023         | 1024~1535        | 1536~2047        | 2048~2559        | 2560~3071        | 3072~3583        | 3584~4095        | 4096~4223             |
| Sector 0<br>512B | Sector 1<br>512B | Sector 2<br>512B | Sector 3<br>512B | Sector 4<br>512B | Sector 5<br>512B | Sector 6<br>512B | Sector 7<br>512B | Spare<br>Area<br>128B |

Table 4-3. MLC Page Layout 4K page (4bit ECC) (4096+128 byte)

# - Spare Area Layout for 4Kbyte/Page NAND Flash Device (4bit ECC Only):

|           |               | •          |                  | ,              |                |                |                | `              | ,              |                |                |              |                      |
|-----------|---------------|------------|------------------|----------------|----------------|----------------|----------------|----------------|----------------|----------------|----------------|--------------|----------------------|
| 0<br>1)   | 1<br>(1)      | 2~3<br>(2) | 4~23<br>(20)     | 24~31<br>(8)   | 32~39<br>(8)   | 40~47<br>(8)   | 48~55<br>(8)   | 56~63<br>(8)   | 64~71<br>(8)   | 72~79<br>(8)   | 80~87<br>(8)   | 88~95<br>(8) | 96~103<br>(8)        |
| ad<br>ark | Clean<br>Mark | Reserved   | Spare<br>Context | Sector0<br>ECC | Sector1<br>ECC | Sector2<br>ECC | Sector3<br>ECC | Sector4<br>ECC | Sector5<br>ECC | Sector6<br>ECC | Sector7<br>ECC | Spare<br>ECC | Spare<br>ECC<br>copy |

Table 4-4. MLC Spare Area layout 4K page (4bit ECC Only) (128 Byte)

For VFLCxt area, those spare area fields have below values.

- Bad Mark : [0xFF]



- Clean Mark : [0x00]
- Reserved : [0xFF][0xFF]
- Spare Context: [0xFF] [0xFF]
   [0xFF] [0xFF] The 5<sup>th</sup> 0x00 is for confirm mark. Incase of 4 KByte page size, there are 8 more [0xFF].
- Sector0 ECC: This value is calculated by 4bit ECC algorithm. This ECC code is for 512
   Bytes of sector 0. The 4 bit ECC algorithm will return the 7 bytes parity code. The 8<sup>th</sup> byte is 0x0.
- Sector1,2,3,4,5,6,7 ECC : Same with above.
- Spare ECC: This value is calculated by 4bit ECC algorithm. This ECC value is for spare area from 4 to 47. Our 4bit ECC algorithm needs to be inputted the 512bytes data to generate ECC parity code. Therefore the (512-44 = 468) bytes deficient have to be filled up with 0xFF. Incase of 4K Byte page size, the area from 4 to 87 have to be calculated with 4 bit ECC algorithm. Therefore the (512-88 = 424)Bytes have to filled up with 0xFF.
- Spare ECC copy: This value is same with Spare ECC.

| Snara Araa I   | Lavout for 4Kbvte/F | Daga NIAND Flach  | Davica (Abit ECC | 1 0hit ECC\. |
|----------------|---------------------|-------------------|------------------|--------------|
| - Spale Alea I | Lavoul IOI 4NDVIE/F | aue inaind riasii | Device (4b)  ECC | TODIL ECCI.  |

| 0 (1)       | 1 (1) | 2~3<br>(2) | 4~23<br>(20)     | 24~31<br>(8) | 32~39<br>(8)   | 40~47<br>(8)   | 48~55<br>(8) | 56~63<br>(8)   | 64~71<br>(8)   | 72~79<br>(8)   | 80~87<br>(8)   | 88~103<br>(16)          | 104~119<br>(16) |
|-------------|-------|------------|------------------|--------------|----------------|----------------|--------------|----------------|----------------|----------------|----------------|-------------------------|-----------------|
| Bad<br>Mark |       | Reserved   | Spare<br>Context |              | Sector1<br>ECC | Sector2<br>ECC | Sector3 ECC  | Sector4<br>ECC | Sector5<br>ECC | Sector6<br>ECC | Sector7<br>ECC | Spare<br>Context<br>ECC | ECC of<br>MECC  |

Table 4-5. MLC Spare Area layout 4K page (4bit ECC) (128 Byte)

For VFLCxt area, those spare area fields have below values.

- Bad Mark: [0xFF]
- Clean Mark: [0x00]
- Reserved : [0xFF][0xFF]
- Spare Context: [0xFF] [0xFF]
   [0xFF] [0xFF] The 5<sup>th</sup> 0x00 is for confirm mark. Incase of 4 KByte page size, there are 8 more [0xFF].
- Sector0 ECC: This value is calculated by 4bit ECC algorithm. This ECC code is for 512
   Bytes of sector 0. The 4 bit ECC algorithm will return the 7 bytes parity code. The 8<sup>th</sup> byte is 0x0.



- Sector1,2,3,4,5,6,7 ECC : Same with above.
- Spare Context ECC: This value is calculated by 8bit ECC algorithm. This ECC code is for spare area from 4 to 23. Our 8bit ECC algorithm needs to be inputted the 512bytes data to generate ECC parity code. Therefore the (512-20 = 492) bytes deficient have to be filled up with 0xFF.
- ECC of MECC: This value is calculated by 8bit ECC algorithm. This ECC code is for spare area from 24 to 87. Our 8bit ECC algorithm needs to be inputted the 512bytes data to generate ECC parity code. Therefore the (512-64 = 448) bytes deficient have to be filled up with 0xFF.
- Page Layout for 4Kbytes/Page NAND Flash Device (8bit ECC):

| 0~511            | 512~1023         | 1024~1535        | 1536~2047        | 2048~2559        | 2560~3071        | 3072~3583        | 3584~4095        | 4096~4313             |
|------------------|------------------|------------------|------------------|------------------|------------------|------------------|------------------|-----------------------|
| Sector 0<br>512B | Sector 1<br>512B | Sector 2<br>512B | Sector 3<br>512B | Sector 4<br>512B | Sector 5<br>512B | Sector 6<br>512B | Sector 7<br>512B | Spare<br>Area<br>218B |

Table 4-6. MLC Page Layout 4K page (8bit ECC) (4096+218 byte)

- Spare Area Layout for 4Kbyte/Page NAND Flash Device (8bit ECC):

| 0 (1)       | 1   | 2~3      | 4~23             | 24~39 | 40~55          | 56~71          | 72~87          | 88~103         | 104~119        | 120~135        | 136~151        | 152~167      | 168~183              |
|-------------|-----|----------|------------------|-------|----------------|----------------|----------------|----------------|----------------|----------------|----------------|--------------|----------------------|
|             | (1) | (2)      | (20)             | (16)  | (16)           | (16)           | (16)           | (16)           | (16)           | (16)           | (16)           | (16)         | (16)                 |
| Bad<br>Mark |     | Reserved | Spare<br>Context |       | Sector1<br>ECC | Sector2<br>ECC | Sector3<br>ECC | Sector4<br>ECC | Sector5<br>ECC | Sector6<br>ECC | Sector7<br>ECC | Spare<br>ECC | Spare<br>ECC<br>copy |

Table 4-7. MLC Spare Area layout 4K page (8bit ECC)(218 Byte)

For VFLCxt area, those spare area fields have below values.

- Bad Mark : [0xFF]

Clean Mark : [0x00]

Reserved : [0xFF][0xFF]

- Spare Context: [0xFF] = The 5<sup>th</sup> 0x00 is for confirm mark. Incase of 4 KByte page size, there are 8 more [0xFF].
- Sector0 ECC: This value is calculated by 4bit ECC algorithm. This ECC code is for 512
   Bytes of sector 0. The 4 bit ECC algorithm will return the 7 bytes parity code. The 8<sup>th</sup>



byte is 0x0.

- Sector1,2,3,4,5,6,7 ECC : Same with above.
- Spare Context ECC: This value is calculated by 8bit ECC algorithm. This ECC code is for spare area from 4 to 151. Our 8bit ECC algorithm needs to be inputted the 512bytes data to generate ECC parity code. Therefore the (512-148 = 364) bytes deficient have to be filled up with 0xFF.
- Spare ECC copy: This value is same with Spare ECC.

| - Page Layout for 8Kbytes | Page NAND Flash | n Device (16bit ECC): |
|---------------------------|-----------------|-----------------------|
|---------------------------|-----------------|-----------------------|

| 0~511            | 512~1023         | 1024~1535         | 1536~2047         | 2048~2559         | 2560~3071         | 3072~3583         | 3584~4095         |                       |
|------------------|------------------|-------------------|-------------------|-------------------|-------------------|-------------------|-------------------|-----------------------|
| Sector 0<br>512B | Sector 1<br>512B | Sector 2<br>512B  | Sector 3<br>512B  | Sector 4<br>512B  | Sector 5<br>512B  | Sector 6<br>512B  | Sector 7<br>512B  |                       |
| 4096~4607        | 4608~5119        | 5120~5631         | 5632~6143         | 6144~6655         | 6656~7167         | 7168~7679         | 7680~8191         | 8192~8627             |
| Sector 8<br>512B | Sector 9<br>512B | Sector 10<br>512B | Sector 11<br>512B | Sector 12<br>512B | Sector 13<br>512B | Sector 14<br>512B | Sector 15<br>512B | Spare<br>Area<br>436B |

Table 4-7. MLC Page Layout 8KB page (16bit ECC) (8192+436 byte)

- Spare Area Layout for 8Kbyte/Page NAND Flash Device (16bit ECC):

| 0 (1) | 1<br>(1) | 2~6<br>(5) | 7~32<br>(26) | 33~55<br>(26) | 59~84<br>(26) | 85~110<br>(26) | 111~136<br>(26) | 137~162<br>(26) | 163~188<br>(26) | 189~214<br>(26) |         |
|-------|----------|------------|--------------|---------------|---------------|----------------|-----------------|-----------------|-----------------|-----------------|---------|
| Bad   | Clean    | Spare      | Sector0      | Sector1       | Sector2       | Sector3        | Sector4         | Sector5         | Sector6         | Sector7         |         |
| Mark  | Mark     | Context    | ECC          | ECC           | ECC           | ECC            | ECC             | ECC             | ECC             | ECC             |         |
|       |          |            | 215~240      | 241~266       | 267~292       | 293~318        | 319~344         | 345~370         | 371~396         | 397~422         | 423~435 |
|       |          |            | (26)         | (26)          | (26)          | (26)           | (26)            | (26)            | (26)            | (26)            | (13)    |
|       |          |            | Sector8      | Sector9       | Sector10      | Sector11       | Sector12        | Sector13        | Sector14        | Sector15        | Spare   |
|       |          |            | ECC          | ECC           | ECC           | ECC            | ECC             | ECC             | ECC             | ECC             | ECC     |

Table 4-8. MLC Spare Area layout 8KB page (16bit ECC)(436 Byte)

For VFLCxt area, those spare area fields have below values.

Bad Mark : [0xFF]Clean Mark : [0x00]

Spare Context: [0xFF] [0xFF] [0xFF] [0xFF] [0x00] - The 5<sup>th</sup> 0x00 is for confirm mark.



- Sector0 ECC: This value is calculated by 16bit ECC algorithm. This ECC code is for
   512 Bytes of sector 0. The 16 bit ECC algorithm will return the 26 bytes parity code.
- Sector1~15 ECC : Same with above.
- Spare Context ECC: This value is calculated by 8bit ECC algorithm. This ECC code is for spare area from 2 to 6 on the spare context.



#### 4.4 Block 0 Image

The Block 0 Image includes NbI1 and NbI2 image.

The Block 0 Image related parameters of SMDHEADER are as below.

- dw2ndBLStartPageNumber
- dw2ndLLastPageNumber
- dw2ndBLAddress
- dw2ndBLSize

The Nbl1 image is written to page 0 and 1, the Nbl2 image is written from page number 9 or 10 to size of Nbl2 image. But the Nbl2 images last page is smaller then 126 page. Because the page number 126 and 127 is used for special purpose.

The block 0 image will be programmed like as below picture based on K9LAG08 MLC NAND flash. The plane 0 and 1 is belonging to first die, and plane 2 and 3 is belonging to second die. Each die is base unit for bad block management and inter-leaving programming.





# 4.4.1 Step loader image

To programming the step loader (Nbl1), the value of dwStepLDRAddress and dwStepLDRSize in SMDHEADER structure have to be referenced. This image has to be programmed on page from 0 to 3. The important thing is from the page number 4 to 8(8KB page sized MLC) or 9 have to be not programmed. It is not allows to write 0xFF.

#### 4.4.2 Second Boot loader image

The second boot loader (Nbl2) will programmed from dw2ndBLStartPageNumber to dw2ndLLastPageNumber. The dw2ndBLStartPageNumber should be page 9(8KB page sized MLC) or 10 and the dw2ndLLastPageNumber have to smaller then page number 125. The 2<sup>nd</sup> boot loader image start address of SMD binary is dw2ndBLAddress value, and the 2<sup>nd</sup> boot loader image size is dw2ndBLSize value.



#### 4.4.3 VFLCxt Bad block info block (126 Page )

The page number 126 has VFLCxt.aBadInfoBlk information. The block 0 page 126 has VFLCxt.aBadInfoBlk for block number from 0 to 4095. The block 4096 page 126 has VFLCxt.aBadInfoBlk for block number from 4096 to 8191. This page contents is depends on initial bad block is in VFLInfo section. Therefore, it needs 4bit ECC algorithm. Most of things for generate spare data is same with VFXCxt spare data generation part.

The first 4 byte data is useful and the remained bytes are filled up with 0xFF.

If the first of VFLCxt Block is bad block, then the array VFLCxt.aBadInfoBlk will be changed from [00][00][00][00] to [01][00][00].





#### 4.4.4 PocketMory Version information (127 Page)

The Page number 127 has PocketMory version information.

This 127 page image related parameters of SMDHEADER are as below.

- dw127Address
- dw127Size

The block 0 page 127 has "220W" data at first 4bytes. The remained data is all 0xFF and the second plane, block 1 page 127, has all 0xFF. The NAND flash fusing machine has to calculate dynamic 4 bit ECC code.

The first 4 byte data is useful and the remained bytes are filled up with 0xFF.

This image is in SMD binary.

```
Page Number [99999999 to exit] = 127
Main Data
ff ff
ff ff ff ff ff ff ff ff ff ff ff ff ff
ff ff ff ff ff ff ff ff ff ff ff
ff ff ff ff ff ff ff ff ff ff ff
ff ff ff ff ff ff ff ff ff ff ff ff
ff ff ff ff ff ff ff ff ff ff ff ff
ff ff ff ff ff ff ff ff ff ff ff ff
Sector 1
Sector 4
f9 25 35 2b c0 70 70 00 d7 ec 33 c6 69 53 80 00
```



#### 4.5 TOC Image

The TOC image is used by Eboot.

This TOC image related parameters of SMDHEADER are as below.

- dwTOCPageNumber
- dwTOCAddress
- dwTOCSize

The dwTOCPageNumber is logical page number. If the dwTOCPageNumber is 256 and this MLC NAND flash use 2 plane programming only, then the TOC block number is logically 1 and physically 2. If the physical block number 2 is bad block, then the TOC image has to be written to logical block number 2, physical block number 4.

#### 4.6 Eboot Image

This Eboot image related parameters of SMDHEADER are as below.

- dwEBootStartPageNumber
- dwEBootLastPageNumber
- dwEbootAddress
- dwEbootSize

The dwEBootStartPageNumber is logical page number. If the dwEBootStartPageNumber is 768 and this MLC NAND flash use 2 plane programming only, then the TOC block number is logically 6(768/128 = 6) physically 3(6/2). If the physical block number 6 is bad block, the TOC image has to be written to block number 8(logical block number 4 \* 2 plane). It follows bad skip algorithm.

### 4.7 Ext Image

This Ext image related parameters of SMDHEADER are as below.

- dwExtStartPageNumber
- dwExtLastPageNumber
- dwExtAddress
- dwExtSize

This region is same with Eboot case.



#### 4.8 OS Image

This OS image related parameters of SMDHEADER are as below.

- dwOSStartPageNumber
- dwOSLastPageNumber
- dwOSAddress
- dwOSSize

This page numbers are logical page number. But the different one with Eboot area is the OS area is controlled by VFL function. (The TOC and Eboot area is controlled by FIL function.) Therefore, if the MLC NAND flash can support inter-leaving function, the page numbers in one logical block is 256.

The page write sequence is as below.

In case of use 2-plane programming and inter-leaving:

| Plane 0  | Plane 1  | Plane 2    | Plane 3    |
|----------|----------|------------|------------|
| Block 20 | Block 21 | Block 4116 | Block 4117 |
| Page 0   | Page 0   | Page 0     | Page 0     |
| Page 1   | Page 1   | Page 1     | Page 1     |
| Page 2   | Page 2   | Page 2     | Page 2     |
| Page 3   | Page 3   | Page 3     | Page 3     |
| Page 4   | Page 4   | Page 4     | Page 4     |
| Page 5   | Page 5   | Page 5     | Page 5     |
| Page 6   | Page 6   | Page 6     | Page 6     |
| Page 7   | Page 7   | Page 7     | Page 7     |
|          |          |            |            |
|          |          |            |            |
|          |          |            |            |
|          |          |            |            |
|          |          |            |            |
| Page 125 | Page 125 | Page 125   | Page 125   |
| Page 126 | Page 126 | Page 126   | Page 126   |
| Page 127 | Page 127 | Page 127   | Page 127   |
|          |          |            |            |
|          |          |            |            |

And it use bad block replacement algorithm. If you met bad block, you should scanning all VFLCxt.aBadMapTable, and if you find the block as marked bad, you have to program the OS



image to indexed block. For example, if you check the block number 60 and this block is bad block, then you have to scan all aBadMapTable array in VFLCxt. And if aBadMapTable[2] value is 60, the bad block replaced block number is dwReservedSectionStartBlock\*2 + 2. The reason of multiple by two is the MLC NAND flash can support 2-plane programming.

# 4.9 File system Image

This file system image related parameters of SMDHEADER are as below.

- dwFTLInfoSectonStartBlock
- dwFTLStartPageNumber
- dwFTLLastPageNumber
- dwFTLAddress
- dwFTLSize

The programming sequence is same with OS area.



#### 4.10 Total block mapping sample

The below picture shows how to each image can written on each blocks.

The total block mapping seems as below picture:



The plane 0 block number 6 and 8 is eboot area. If the block number 8 is bad block, it skip the bad block and write to next block.

The plane 0 block number 22 and 292 is bad block and it is OS area or file system area. This



block replaced to reserved area Block number 94 and 95.

The second die, plane 2 and 3, has 5 bad blocks. It is remapped to block number 4190, 4191, 4193.

If the VFLCxt Block is bad block, it will written to next block in same plane. (4182 -> 4184)

This picture assume the below setting values.

```
BOOL32bUse2Plane = TRUE32;
BOOL32bUseInterLeaving = TRUE32;
DWORDdwTotalBlockNumber = 8192;
DWORD dwSpecialAreaStartBlock = 10;
DWORDdwVFLInfoSectionStartBlock = 43;
DWORD dwReservedSectionStartBlock = 47;
DWORD dwReservedSectionBlockNumber = 102;
DWORDdwFTLInfoSectonStartBlock = 149;
DWORDdwTOCPageNumber = 128;
DWORD dwEBootStartPageNumber = 384;
DWORDdwEBootLastPageNumber = ??;
                                      // It depends on Eboot size.
DWORD dwOSStartPageNumber = 2560;
                                      // 10*256
DWORDdwOSLastPageNumber = ??;
                                              // It depends on OS size.
DWORD dwVFLInfoSectionPageNumber 11008;
                                               // (86/2)*256
DWORDdwFTLStartPageNumber = 37120;
                                             // (290/2)*256
DWORDdwFTLLastPageNumber = ??;
                                      // It depends on Filesystem size
```